f(cons(nil, y)) → y
f(cons(f(cons(nil, y)), z)) → copy(n, y, z)
copy(0, y, z) → f(z)
copy(s(x), y, z) → copy(x, y, cons(f(y), z))
↳ QTRS
↳ DependencyPairsProof
f(cons(nil, y)) → y
f(cons(f(cons(nil, y)), z)) → copy(n, y, z)
copy(0, y, z) → f(z)
copy(s(x), y, z) → copy(x, y, cons(f(y), z))
COPY(s(x), y, z) → F(y)
COPY(0, y, z) → F(z)
COPY(s(x), y, z) → COPY(x, y, cons(f(y), z))
F(cons(f(cons(nil, y)), z)) → COPY(n, y, z)
f(cons(nil, y)) → y
f(cons(f(cons(nil, y)), z)) → copy(n, y, z)
copy(0, y, z) → f(z)
copy(s(x), y, z) → copy(x, y, cons(f(y), z))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
COPY(s(x), y, z) → F(y)
COPY(0, y, z) → F(z)
COPY(s(x), y, z) → COPY(x, y, cons(f(y), z))
F(cons(f(cons(nil, y)), z)) → COPY(n, y, z)
f(cons(nil, y)) → y
f(cons(f(cons(nil, y)), z)) → copy(n, y, z)
copy(0, y, z) → f(z)
copy(s(x), y, z) → copy(x, y, cons(f(y), z))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
COPY(s(x), y, z) → F(y)
COPY(0, y, z) → F(z)
COPY(s(x), y, z) → COPY(x, y, cons(f(y), z))
F(cons(f(cons(nil, y)), z)) → COPY(n, y, z)
f(cons(nil, y)) → y
f(cons(f(cons(nil, y)), z)) → copy(n, y, z)
copy(0, y, z) → f(z)
copy(s(x), y, z) → copy(x, y, cons(f(y), z))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ QDP
↳ QDPOrderProof
COPY(s(x), y, z) → COPY(x, y, cons(f(y), z))
f(cons(nil, y)) → y
f(cons(f(cons(nil, y)), z)) → copy(n, y, z)
copy(0, y, z) → f(z)
copy(s(x), y, z) → copy(x, y, cons(f(y), z))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
COPY(s(x), y, z) → COPY(x, y, cons(f(y), z))
COPY1 > cons1 > f1
s1 > cons1 > f1
nil > copy2 > f1
n > f1
copy2: multiset
COPY1: multiset
f1: multiset
s1: multiset
nil: multiset
cons1: multiset
n: multiset
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
f(cons(nil, y)) → y
f(cons(f(cons(nil, y)), z)) → copy(n, y, z)
copy(0, y, z) → f(z)
copy(s(x), y, z) → copy(x, y, cons(f(y), z))